import request from "@/nxTemp/request";
import store from '@/nxTemp/store';
import config from '@/nxTemp/config/index.config.js';

//可以new多个request来支持多个域名请求
let $http = new request({
	//接口请求地址
	baseUrl: config.baseUrl,
	//服务器本地上传文件地址
	fileUrl: config.baseUrl,
	// 服务器上传图片默认url
	defaultUploadUrl: "upload/image",
	//设置请求头（如果使用报错跨域问题，可能是content-type请求类型和后台那边设置的不一致）
	header: {
		'Content-Type': 'application/json;charset=UTF-8',

	}
});

//请求开始拦截器
$http.requestStart = function(options) {
	// console.log("请求开始", options);
	if (options.load) {
		//打开加载动画
		store.commit("setLoadingShow", true);
	}
	// 图片上传大小限制
	if (options.method == "FILE" && options.maxSize) {
		// console.log("请求开始1", options);
		// 文件最大字节: options.maxSize 可以在调用方法的时候加入参数
		let maxSize = options.maxSize;
		for (let item of options.files) {
			if (item.size > maxSize) {
				setTimeout(() => {
					uni.showToast({
						title: "图片过大，请重新上传",
						icon: "none"
					});
				}, 500);
				return false;
			}
		}
	}
	if (options.url) {
		//请求前加入token
		let url = options.url.substring(options.url.lastIndexOf('/') + 1);
		if (url != 'login') {
			let token = uni.getStorageSync('token');
			if (!token) {
				store.dispatch('reLogin', '');
			} else {
				options.header['token'] = uni.getStorageSync('token');
			}
		}
	}

	// console.log(options,'header')
	return options;
}
//请求结束
$http.requestEnd = function(options) {
	//判断当前接口是否需要加载动画
	if (options.load) {
		// 关闭加载动画
		store.commit("setLoadingShow", false);
	}
}
//所有接口数据处理（此方法需要开发者根据各自的接口返回类型修改，以下只是模板）
$http.dataFactory = async function(res) {
	// console.log("接口请求数据", {
	// 	url: res.url,
	// 	resolve: res.response,
	// 	header: res.header,
	// 	data: res.data,
	// 	method: res.method,
	// });
	if (res.response.statusCode && res.response.statusCode == 200) {
		let httpData = res.response.data;
		if (typeof(httpData) == "string") {
			httpData = JSON.parse(httpData);

		}
		//判断数据是否请求成功
		// if (httpData.success || httpData.code == 200) {
		if (httpData.code == 0) {
			// 返回正确的结果(then接受数据)
			return Promise.resolve(httpData);
			// return Promise.resolve(httpData.data);
		} else if (httpData.code == "1000" || httpData.code == "1001" || httpData.code == 1100 || httpData
			.code == 402) {


			store.commit("emptyUserInfo");
			// #ifdef MP-WEIXIN
			// onLogin();跳转登录页面
			// #endif


			// 返回错误的结果(catch接受数据)
			return Promise.reject({
				statusCode: 0,
				errMsg: "【request】" + (httpData.info || httpData.msg),
				data: res.data
			});
		} else if (httpData.code == "401") { // token失效
			uni.showToast({
				title: "登录状态失效请重新登录",
				icon: "none"
			});
			uni.setStorageSync("token", null);
			setTimeout(() => {
				uni.reLaunch({
					url: '/pages/my/index'
				});
			}, 2000);


		} else { //其他错误提示   
			if (res.isPrompt) {
				uni.showToast({
					title: httpData.info || httpData.msg,
					icon: "none",
					duration: 3000
				});
			}
			// 返回错误的结果(catch接受数据)
			return Promise.reject({
				statusCode: 0,
				errMsg: "【request】" + (httpData.info || httpData.msg),
				data: res.data
			});
		}

	} else {
		// 返回错误的结果(catch接受数据)
		return Promise.reject({
			statusCode: res.response.statusCode,
			errMsg: "【request】数据工厂验证不通过",
			data: res.data
		});
	}
};
// 错误回调
$http.requestError = function(e) {
	if (e.statusCode === 0) {
		throw e;
	} else {
		// console.log(e);
		uni.showToast({
			title: "网络错误，请检查一下网络",
			icon: "none"
		});
	}
}
export default $http;